<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>key的原理</title>
    <script src="../js/vue.js"></script>
</head>
<body>
    <!-- 
        key有什么作用？key的原理。
            1.虚拟DOM中key的作用：
                key是虚拟DOM对象的标识，当数据发生变化时，Vue会根据新数据生成新虚拟DOM，
                随后Vue进行新虚拟DOM与旧虚拟DOM的差异比较，比较规则如下：

            2.对比规则：
                1.旧虚拟DOM中找到了与新虚拟DOM相同的key：
                    若虚拟DOM中内容没有变化，直接使用之前的真是DOM。
                    若虚拟DOM中内容发生变化，则生成新的虚拟DOM，随后替换掉页面中之前的真实DOM。
                2.旧虚拟DOM未找到与新虚拟DOM相同的key：
                    创建新的虚拟DOM，然后渲染到页面。

            3.用index作为key可能会引发的问题：
                1.若对数据进行：逆序添加、逆序删除等破坏顺序操作；
                    会产生没有必要的真实DOM更新。，真实效率没有问题，但是效率低。
                
                2.如果结构中还包含输入类的DOM：会产生错误DOM更新==》界面有问题。

            4.开发中如何选择key：
                1.最好使用每条数据唯一的标识作为key，比如id，手机号，身份证号等唯一值。
                2.如果不存在对数据的逆序添加、逆序删除等破坏顺序操作，仅使用渲染列表进行展示，
                使用index作为key是没有问题的。


     -->
    <div id="root">
        <!-- 遍历数组 -->
        <ul>
            <li v-for="(p,index) in persons" :key="index">
                姓名：{{p.name}},
                年龄：{{p.age}}
            </li>
        </ul>
        
    </div>

    <script>
        new Vue({
            el:'#root',
            data:{
                persons:[
                    {id:'001',name:'张三',age:'18'},
                    {id:'002',name:'李四',age:'19'},
                    {id:'003',name:'王五',age:'20'}
                ],
            }
        })
    </script>
</body>
</html>